home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
Chip: 2001 Haziran
/
CHIP Haziran2001.iso
/
prog
/
haziran
/
19
/
setup.exe
/
data.z
/
altera_lib.h
< prev
next >
Wrap
C/C++ Source or Header
|
2001-04-11
|
4KB
|
134 lines
//////////////////////////////////////////////////////////////////////
// File - altera_lib.h
//
// Library for accessing the ALTERA card,
// Code was generated by Driver Wizard.
// It accesses the hardware via WinDriver functions.
//
//////////////////////////////////////////////////////////////////////
#ifndef _ALTERA_LIB_H_
#define _ALTERA_LIB_H_
#ifdef __KERNEL__
#include "../../../include/kdstdlib.h"
#endif //__KERNEL__
#include "../../../include/windrvr.h"
#include "../../../samples/shared/pci_regs.h"
#include "../../../samples/shared/bits.h"
#ifdef __cplusplus
extern "C" {
#endif
enum { ALTERA_DEFAULT_VENDOR_ID = 0x1172 };
enum { ALTERA_DEFAULT_DEVICE_ID = 0x0004 };
typedef enum
{
ALTERA_MODE_BYTE = 0,
ALTERA_MODE_WORD = 1,
ALTERA_MODE_DWORD = 2
} ALTERA_MODE;
typedef enum
{
ALTERA_AD_BAR0 = AD_PCI_BAR0,
ALTERA_AD_BAR1 = AD_PCI_BAR1,
ALTERA_AD_BAR2 = AD_PCI_BAR2,
ALTERA_AD_BAR3 = AD_PCI_BAR3,
ALTERA_AD_BAR4 = AD_PCI_BAR4,
ALTERA_AD_BAR5 = AD_PCI_BAR5,
ALTERA_AD_EPROM = AD_PCI_BAR_EPROM,
ALTERA_ITEMS = AD_PCI_BARS
} ALTERA_ADDR;
typedef struct ALTERA_STRUCT *ALTERA_HANDLE;
typedef struct
{
DWORD dwCounter; // number of interrupts received
DWORD dwLost; // number of interrupts not yet dealt with
BOOL fStopped; // was interrupt disabled during wait
} ALTERA_INT_RESULT;
typedef void (WINAPI *ALTERA_INT_HANDLER)( ALTERA_HANDLE hALTERA, ALTERA_INT_RESULT *intResult);
// options for ALTERA_Open
enum { ALTERA_OPEN_USE_INT = 0x1 };
BOOL ALTERA_Open (ALTERA_HANDLE *phALTERA, DWORD dwVendorID, DWORD dwDeviceID, DWORD nCardNum, DWORD options);
void ALTERA_Close(ALTERA_HANDLE hALTERA);
DWORD ALTERA_CountCards (DWORD dwVendorID, DWORD dwDeviceID);
BOOL ALTERA_IsAddrSpaceActive(ALTERA_HANDLE hALTERA, ALTERA_ADDR addrSpace);
void ALTERA_GetPciSlot(ALTERA_HANDLE hALTERA, WD_PCI_SLOT *pPciSlot);
// General read/write function
void ALTERA_ReadWriteBlock(ALTERA_HANDLE hALTERA, ALTERA_ADDR addrSpace, DWORD dwOffset, BOOL fRead, PVOID buf, DWORD dwBytes, ALTERA_MODE mode);
BYTE ALTERA_ReadByte (ALTERA_HANDLE hALTERA, ALTERA_ADDR addrSpace, DWORD dwOffset);
WORD ALTERA_ReadWord (ALTERA_HANDLE hALTERA, ALTERA_ADDR addrSpace, DWORD dwOffset);
DWORD ALTERA_ReadDword (ALTERA_HANDLE hALTERA, ALTERA_ADDR addrSpace, DWORD dwOffset);
void ALTERA_WriteByte (ALTERA_HANDLE hALTERA, ALTERA_ADDR addrSpace, DWORD dwOffset, BYTE data);
void ALTERA_WriteWord (ALTERA_HANDLE hALTERA, ALTERA_ADDR addrSpace, DWORD dwOffset, WORD data);
void ALTERA_WriteDword (ALTERA_HANDLE hALTERA, ALTERA_ADDR addrSpace, DWORD dwOffset, DWORD data);
// handle interrupts
BOOL ALTERA_IntIsEnabled (ALTERA_HANDLE hALTERA);
BOOL ALTERA_IntEnable (ALTERA_HANDLE hALTERA, ALTERA_INT_HANDLER funcIntHandler);
void ALTERA_IntDisable (ALTERA_HANDLE hALTERA);
// access to PCI configuration registers
void ALTERA_WritePCIReg(ALTERA_HANDLE hALTERA, DWORD dwReg, DWORD dwData);
DWORD ALTERA_ReadPCIReg(ALTERA_HANDLE hALTERA, DWORD dwReg);
void ALTERA_WritePCIRegN(ALTERA_HANDLE hALTERA, DWORD dwReg, DWORD dwData, DWORD dwBytes);
DWORD ALTERA_ReadPCIRegN(ALTERA_HANDLE hALTERA, DWORD dwReg, DWORD dwBytes);
BOOL ALTERA_DMAReadWriteBlock(ALTERA_HANDLE hALTERA, DWORD dwLocalAddr, PVOID pBuffer, BOOL fRead, DWORD dwBytes, BOOL fChained);
// this string is set to an error message, if one occurs
extern CHAR ALTERA_ErrorString[];
enum {
ALTERA_REG_DMACSR = 0x0, /* 0 Control Status register */
ALTERA_REG_DMAACR = 0x4, /* 4 PCI Address - Host memory address */
ALTERA_REG_DMABCR = 0x8, /* 8 Byte Count Register - In SG mode */
ALTERA_REG_DMAISR = 0xc, /* c Interrupt Status register */
ALTERA_REG_DMALAR = 0x10,
ALTERA_REG_SDRAM_BAR = 0x18,
ALTERA_REG_SDRAM_CFG0 = 0x1c,
ALTERA_REG_SDRAM_CFG1 = 0x20,
ALTERA_REG_SDRAM_CFG2 = 0x24,
ALTERA_REG_TARG_PERF = 0x80,
ALTERA_REG_MSTR_PERF = 0x84,
};
enum {
INTERRUPT_ENABLE = 0x0001,
DMA_ENABLE = 0x0010,
TRXCOMPINTDIS = 0x0020,
CHAINEN = 0x0100,
DIRECTION = 0x0008,
};
enum { FIFO_BASE_OFFSET = 512 * 1024 }; // was 16 * 1M
enum { SDRAM_BASE_OFFSET = 0 }; // was 32 * 1M
enum { ALTERA_DMA_FIFO_REGS = 128 };
// ISR
enum {
INTERUPT_PENDING = 0x01,
ERROR_PENDING = 0x02,
LOCAL_REQ = 0x04,
TX_COMP = 0x08,
ACR_LOADED = 0x10,
CHAIN_STARTED = 0x20,
};
#ifdef __cplusplus
}
#endif
#endif